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COMPUTER SYSTEM AND METHOD FOR PROVIDING DIGITAL VIDEO 
AND DATA OVER A COMMUNICATION CHANNEL 

CROSS-REFERENCE TO RELATED APP LICATIONS 
This document claims priority to and the benefit of the filing date of 
provisional patent application entitled DIGITAL VIDEO AND DATA SYSTEM, 
assigned serial number 60/064,1 53, and filed November 4, 1 997 the text of which is 
hereby incorporated by reference, and is related to the following commonly assigned 
copending U.S. Patent Applications: SYSTEM AND METHOD FOR THE 
DELIVERY OF DIGITAL VIDEO AND DATA OVER A COMMUNICATION 
CHANNEL, filed on even date herewith (Attorney Docket Number 62002-1990), 
SYSTEM AND METHOD FOR MAINTAINING TIMING SYNCHRONIZATION 
IN A DIGITAL VIDEO NETWORK, filed on even date herewith (Attorney Docket 
Number 62004-1050), and APPARATUS AND METHOD FOR TRANSPORTING 
INFRARED AND RADIO FREQUENCY SIGNALS, filed on even date herewith 
(Attorney Docket Number 62004-1060), which are all hereby incorporated by 
reference. 

TECHNICAL FIELD 

The present invention relates generally to the delivery of digital video and 
data, and more particularly, to a computer system and method for the delivery of 
digital video and data over a communication channel. 

RACKfiROUND OF THE INVENTION 

The delivery of digital video signals to a subscriber has been accomplished via 
many ways. For example, compressed digital video using the motion picture experts 
group (MPEG-2) compression/decompression methodology can be delivered using a 
variety of media including coaxial cable, fiber optic cable and satellite. Some of these 
delivery systems are considered "video-on-demand", or "near video-on-demand" in 
that a user, or subscriber, may select firom a plurality of offerings and view a particular 
program as desired fi-om time to time. In video-on-demand systems a user may select 
a program for viewing at any arbitrary time. In near video-on-demand systems, a user 
is typically given a choice of programming available at repeated specific times. 
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Furthermore, broadcast video applies to programming that occurs with a daily or 
weekly schedule and is delivered to a wide number of subscribers at the same time. 

These systems typically make available to the user all channels of 
programming from which the user selects the desired program, typically through the 

5 use of some sort of converter or decoder box located near a television set. For 

example, in a typical cable television system, all available programming is delivered 
to a user via a coaxial cable that terminates near the user's premises. The 
programming made available to each particular user is determined by the insertion of 
a filter, or a scrambler, between the supply cable and the user's premises. In this 

10 manner, the selection available to a user is controlled. In these cable television 

systems, a "pay-per-view" system is also available through the use of the converter 
box. If the user desires a particular program, the user contacts the cable service 
provider ahead of time in order to purchase that particular program. 

In satellite digital video delivery systems a user, or subscriber, installs a small 

15 parabolic reflector and special electronics at the premises. These systems use the 

direct broadcast satellite "DBS" spectrum to deliver digital video signals to a user. In 
these systems, all of the available programming content is transmitted directly to all 
users from specialized satellites in geosynchronous earth orbit. Geosynchronous orbit 
refers to an orbit in which a satellite orbiting the earth remains in a fixed position 

20 relative to a point on the earth. A receiver unit located at the user premises decodes 
the data stream in order to extract the desired programming. 

Each of the aforementioned digital video delivery systems have drawbacks. 
For example, in cable television systems, it is relatively easy to steal, or pirate, the 
signal from the cable located near the user premises. This allows an unauthorized user 

25 access to all programming available on the cable. Furthermore, historically, cable 
television systems suffer fi*om reliability problems. 

A satellite delivery system also has drawbacks. Because all of the available 
programming is simultaneously beamed to all subscribers, bandwidth allocation, and 
therefore, channel capacity, becomes critical. For example, during times when many 

30 sporting events or high action programming that contain fast motion are broadcast 
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simultaneously, such as on Sunday afternoons during football season, additional 
bandwidth must be made available to certain channels. Because the amount of 
available bandwidth is fixed, this necessitates the reduction of bandwidth available for 
other channels. In addition, satellite delivery systems rely upon the proper installation 
of the parabolic reflector, which must have an unobstructed line of sight to the 
transmitting satellite or satellites, and suffer from signal degradation in inclement 
weather. Furthermore, as in cable television systems, or in any system in which all 
channels are dehvered to all customers, it is possible to obtain unauthorized channels. 

Other available systems make a number of video programs available to an end 
user by employing an asynchronous transmission network (ATM) over which a 
particular program may be delivered to an end user. Unfortunately, ATM systems are 
costly to implement and because these systems employ an ATM switching fabric, they 
can easily become overloaded if, for example, a large number of users chose to view a 
wide variety of programs. 

Thus, a heretofore unaddressed need exists in the industry to address the 
aforementioned deficiencies and inadequacies. 

SUMMARY OF THE INVENTION 

The present invention provides a computer system and method for the 
delivery of digital video, bi-directional data, such as Internet data, and plain old 
telephone service (POTS). 

Briefly described, the system can be implemented as follows. A software 
management system for managing a digital video and data delivery system in which a 
plurality of channels are simultaneously available to at least one user, and wherein a 
user may request at least one of a plurality of video channels, comprises means for 
managing a database containing user information, means for managing a plurality of 
channels including a plurality of video channels available on a bus and at least one bi- 
directional data channel. Also included is means for communicating with a plurality 
of central office master workstations in order to exchange information relating to the 
user information and the plurality of channels, means for processing a request from 
the user to view one of the plurality of video channels, and means for delivering at 
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least one of the plurality of video channels and at least one bi-directional data channel 
to the user over a communications channel. 

The present invention also includes a software management system for 
managing digital video and data delivery equipment in which a plurality of channels 

5 are simultaneously available to at least one user, and wherein said user may request 
any one of said plurality of channels, comprising means for managing a database 
containing subscriber information, means for monitoring a plurality of channels, 
including a plurality of video channels available on a bus and at least one bi- 
directional data channel, and means for processing a request from a user to view at 

10 least one of the plurality of video channels. Also included are means for assigning a 
communications port to the user when the user requests to be a subscriber, and means 
for delivering at least one of the plurality of video channels and at least one bi- 
directional data channel to the user over a communications channel. 

BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWINGS 

15 The invention can be better understood with reference to the following 

drawings. The components in the drawings are not necessarily to scale, emphasis 
instead being placed upon clearly illustrating the principles of the present invention. 
Moreover, in the drawings, like reference numerals designate corresponding parts 
throughout the several views. 

20 Fig. 1 A is a high level system view illustrating the overall topology in which 

the digital video and data delivery system of the present invention resides; 

Fig. IB is a flow chart illustrating the manner in which a user requests a 
program via the system topology of Fig. 1 A; 

Fig. 2 is a schematic view illustrating the delivery of digital video from 

25 content provider 1 1 to telco progranuning and control center 1 00; 

Fig. 3 is a schematic view illustrating the architecture that connects telco 
programming and control center 1 00 to central office 400; 

Fig. 4 is a block diagram illustrating the components of the present invention 
that reside within telco programming and control center 100; 

30 Fig. 5 is a block diagram illustrating the video control shelf 200 of Fig, 4; 
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Fig. 6 is a block diagram illustrating the video control module 250 of Fig. 5; 
Fig. 7 is a schematic view illustrating the shelf processor module 300 of Fig. 

5; 

Fig. 8 is a flow diagram illustrating the architecture, functionality, and 
operation of a possible implementation of the system management workstation 325 of 
Fig. 4; 

Fig. 9 is a schematic view illustrating the architecture of central office 400; 
Fig. 1 OA is a schematic view illustrating the video network interface shelf 450 
of Fig. 9; 

Fig. 1 OB is a block diagram illustrating the video network interface module 
700 of Fig. lOA; 

Fig. 1 1 A is a schematic view illustrating the video distribution shelf 500 of 

Fig. 9; 

Fig. 1 IB is a block diagram illustrating the video input module 800 of Fig. 

IIA; 

Fig. lie is a schematic view illustrating an alternative distribution scheme to 
the video input module of Fig. 1 IB; 

Fig. 1 ID is a block diagram illustrating the multiple video output module 850 
of Fig. 11 A; 

Fig. 1 IE is a schematic view illustrating a remote video output module of Fig. 

11 A; 

Fig. 12 is a schematic view illustrating the access shelf 550 and the low pass 
filter module 600 of Fig. 9; 

Fig. 13 is a schematic view illustrating additional detail of access shelf 550 of 

Fig. 9; 

Fig. 14 is a schematic view illustrating imiversal access adapter module 1000 
of Figs. 12 and 13; 

Fig. 15 is a flow diagram of central office master workstation 650 of Fig. 9; 
Fig. 16 is a block diagram illustrating customer premise 1300; 
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Fig. 17A is a schematic view illustrating the intelligent network interface (INI) 
1350 of Fig. 16; 

Fig. 17B is a schematic view illustrating the system in which the IR remote 
control interface of Fig. 17A is installed; 
5 Fig. 17C is a schematic view illustrating an IR remote transceiver of Fig. 1 7B: 

Fig. 17D is a schematic view illustrating the IR remote control interface 1358 
of Fig. 17A; 

Fig. 18 is a schematic view illustrating the location, and a possible 
implementation, of CO framer 1 100 and CP framer 1400 within the digital video and 
1 0 data delivery system of the present invention; 

Fig. 19 is a schematic view illustrating CO framer 1 100 of Fig. 18; 

Fig. 20A is a schematic view illustrating the adaptive rate transport stream bus 
specification of the transport stream of Fig. 1 9; 

Fig. 20B is a schematic view illustrating the formatting used to transport eight 
15 sets of the adaptive rate transport stream of Fig. 20A over an optical link; 

Fig. 21 is a schematic view illustrating that upon the removal of data content 
from the adaptive style transport stream of Fig. 20, remaining is a fixed rate transport 
stream bus; 

Fig. 22 is an excerpt from the MPEG-2 transport stream specification defining 
20 the first three bytes of the transport stream packet of Figs. 20 and 2 1 ; 

Fig. 23 is a schematic view illustrating the transport stream contained on 
connection 1161 of Fig. 19; 

Fig. 24A is a schematic view illustrating PID filter 1110 of Fig. 19; 

Fig. 24B is a decision flow diagram illustrating the operation of the PID filter 
25 11 10 of Fig. 24 A; 

Fig. 25 is a decision flow diagram illustrating the operation of the PGR extract 
device 1130 of Fig. 19; 

Fig. 26 is a detailed view of the PCR incrementor 1 140 of Fig. 19; 

Fig. 27A is a block diagram illustrating CO data mux 1 150 of Fig. 19; 
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Fig. 27B is a state diagram illustrating the operation of CO data mux 1 150 of 
Fig. 19; 

Fig. 27C is a flow chart illustrating the operation of CO data mux 11 50 of Fig. 

27A; 

Fig. 27D is a flow chart illustrating the CO data mux program packet decision 
making function 11 52 of Fig. 27A; 

Fig. 28 is a schematic view illustrating the downstream (from central office to 
customer premise) operation of CO framer 1 100 of Fig. 19; 

Fig. 29 is a schematic view illustrating the CO data mux of CO framer 1 100 of 
Fig. 19 in an upstream (customer premises to central office) direction.; 

Fig. 30 is a schematic view illustrating the CP data demux of Fig. 17A in a 
downstream direction; 

Fig. 31 is a schematic view illustrating CP data mux 1450 of the CP framer 
1400 of Fig. 17A in an upstream direction; 

Fig. 32 is a decision flow diagram illustrating the operation of both CO data 
demux 1 155 and CP data demux 1455; 

Fig. 33 is a flow chart illustrating the operation of CP data mux 1450 of Fig. 
17 A; and 

Fig. 34 is a schematic view illustrating an altemative embodiment of CO 
framer 1100 of Fig. 19. 

DETAILED DESCRIPTION OF THE INVENTION 

The digital video and data delivery program of the present invention can be 
implemented in hardware, software, firmware, or a combination thereof. In the 
prefened embodiment(s), the digital video and data delivery program is implemented 
in hardware that is managed by software or firmware that is stored in a memory and 
that is executed by a suitable instruction execution system. 

The flow chart of Figs. 8 and 15 show the architecture, fimctionality, and 
operation of a possible implementation of the system management workstation of Fig. 
4 and the central office master workstation of Fig. 9. In this regard, each block 
represents a module, segment, or portion of code, which comprises one or more 
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executable instructions for implementing the specified logical function(s). It should 
also be noted that in some alternative implementations, the functions noted in the 
blocks may occur out of the order noted in Figs 8 and 1 5. For example, two blocks 
shown in succession in Figs. 8 and 15 may in fact be executed substantially 
concurrently or the blocks may sometimes be executed in the reverse order, depending 
upon the functionality involved, as will be further clarified hereinbelow. 

The digital video and data delivery program, which comprises an ordered 
listing of executable instructions for implementing logical functions, can be embodied 
in any computer-readable medium for use by or in connection with an instruction 
execution system, apparatus, or device, such as a computer-based system, processor- 
containing system, or other system that can fetch the instructions from the instruction 
execution system, apparatus, or device and execute the instructions. In the context of 
this document, a "computer-readable medium" can be any means that can contain, 
store, communicate, propagate, or transport the program for use by or in connection 
with the instruction execution system, apparatus, or device. The computer readable 
medium can be, for example but not limited to, an electronic, magnetic, optical, 
electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation 
medium. More specific examples (a nonexhaustive list) of the computer-readable 
medium would include the following: an electrical connection (electronic) having one 
or more wires, a portable computer diskette (magnetic), a random access memory 
(RAM) (magnetic), a read-only memory (ROM) (magnetic), an erasable 
programmable read-only memory (EPROM or Flash memory) (magnetic), an optical 
fiber (optical), and a portable compact disc read-only memory (CDROM) (optical). 
Note that the computer-readable medium could even be paper or another suitable 
medium upon which the program is printed, as the program can be electronically 
captured, via for instance optical scanning of the paper or other medium, then 
compiled, interpreted or otherwise processed in a suitable maimer if necessary, and 
then stored in a computer memory. 

Fig. 1 A is a high level system view illustrating the overall topology in which 
the digital video and data delivery system of the present invention resides. Included 
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in system topology 10 are telephone company programming and control center 
(TPCC) 100, central office 400, and customer premises 1300. TPCC 100 receives 
input from local broadcaster 12, which provides broadcast television signals, content 
provider 11, which provides digital video signals in the form of MPEG-2 encoded 

5 video, and data from Internet service provider (ISP) 1 4. While illustrated herein as 

transporting Internet data, indeed any data, such as for example but not limited to 
local area network (LAN) or any digital data may be transported in accordance with 
the present invention. TPCC 100 communicates with central office 400 over SONET 
network (synchronous optical network) 150. While a single central office is shown 

10 for simplicity, TPCC 100 may communicate with a plurality of central office locations 
400 over SONET network 150. SONET network 150 represents one manner in which 
a TPCC may communicate with central office locations and is typically the internal 
telephone company network that connects multiple central offices with each TPCC. 
SONET network 150 is used for illustrative purposes only. Other internal networks, 

15 such as, for example but not limited to, an SDH (synchronous digital hierarchy) 
network or any method of communicating between TPCC 100 and central office 
locations 400 may be used to communicate between TPCC 100 and central office 400. 
Central office 400 communicates with customer premises 1300 over communication 
channel 16. Communication channel 16 can be any communication channel capable 

20 of supporting the commxmication of compressed digital video, bi-directional Internet 

data and POTS, and is illustratively carried over the copper wire pair over which 
conventional telephone signals are communicated. Other communication channels, 
for example but not limited to a vdreless communication channel such as an LMDS 
(local multipoint distribution system), may be used to communicate between central 

25 office 400 and customer premises 1300. Located at customer premises 1300 are 
intelligent network interface (INI) 1350 to which are connected computer system 
1355, telephone 1360, fax machine (not showoi), and television 1365. It is also 
possible to provide an additional digital telephony communication line to which may 
be connected a fax machine. The digital video and data delivery system and method 

30 of the present invention operate to allow TPCC 1 00 to deliver to central office 400, 
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and central office 400 to deliver to customer premises 1 300 over a communication 
channel 16, compressed digital programming, bi-directional Internet data, and POTS. 

Fig. IB is a flow chart illustrating the manner in which a user requests a 
program via the system topology of Fig. 1 A. In block 5 1 a user sends a request to 
central office 400 to view a particular program. The request is sent via a control 
channel (to be described in detail below) over communication channel 16. In block 
52 the request is received in central office 400. In block 54 a central office universal 
access adapter (UAA), which handles the request using tables supplied to it by a 
central office master workstation that informs the UAA what is authorized, processes 
the request and in block 56, if the user is authorized to receive the requested program, 
the program is delivered to the user from central office 400 via communication 
channel 16. 

Fig. 2 is a schematic view illustrating the delivery of video content from 
content provider 1 1 to TPCC 100. Content provider 1 1 receives an analog video 
signal illustratively via satellite 17. Alternatively, content provider 1 1 receives 
digitally encoded video signals illustratively via satellite 17. It should be understood 
that audio content accompanies the video signals referred to herein, and when 
referring to video, or compressed digital video, it is understood that the audio signal is 
included. Content provider 1 1 delivers the analog (or digital) video signals over 
network 13 to a plurality of TPCCs 100. Network 13 can be, for example but not 
limited to, a satellite delivery network or possibly a SONET network similar to 
SONET network 150 of Fig. 1. TPCCs 100 receive local broadcast video 
progranmiing from local broadcasters 12. 

Fig. 3 is a schematic view illustrating the architecture that connects TPCC 100 
to central offices 400. As discussed above, TPCC 100 receives video, m the form of 
an analog or a digital signal from content provider 1 1, local broadcast television from 
local broadcaster 12, and Internet data from ISP 14. TPCC 100 integrates the 
aforementioned content and provides it to central offices 400 over Telco SONET 
network 1 50, or via any network used to communicate between TPCC 100 and central 
office locations 400. 
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Fig. 4 is a block diagram illustrating the components of the present invention 
that reside within TPCC 100. Within TPCC 100 bi-directional data from ISP 14, 
video content from content provider 11 (of Figs. 1 and 2) and local programming from 
local broadcaster 12 are combined. Bi-directional Internet data are supplied from ISP 
14 over connection 128 to router 101. Router 101 communicates over connection 1 12 
with ATM switch 102, which communicates with SONET add-drop multiplexer 106 
over connection 1 14. SONET add-drop mux 106 is shown for illustrative purposes 
only, and would be an SHD multiplexer if an SDH network were implemented in 
place of SONET network 1 50. In this manner, Internet data are processed by TPC 
100 and forwarded to central offices 400 over SONET network 150. Also 
communicated over connection 1 14 are management and control data from system 
management workstation 325, which will be described in detail below. Video content 
is supplied from content provider 1 1 over connection 126 to satellite receiver 104. If 
the video content supphed from content provider 1 1 is in the form of an analog signal, 
then it is supplied over connection 115 to MPEG-2 encoder 109 for conversion to 
MPEG-2 format. Although MPEG-2 is used in the preferred embodiment, any digital 
compression technique may be used to generate the compressed digital video signal. 
If the video content supplied by content provider 1 1 is in the form of a digital signal, 
then it is supplied directly to video control shelf 200 via connection 118. Connection 
1 1 8 is illustratively a plurality of DS-3 connections and in the preferred embodiment 
is a total of seven (7) DS-3 connections. A DS-3 connection provides approximately 
45 megabits/second (Mb/s) of data transfer, and is used herein illustratively. 

Indeed, connection 1 1 8 can be made up of a plurality of any high, capacity 
channel, for example but not limited to, an OC-3 connection, which provides 
approximately 155 megabits of capacity. Local programming from local broadcaster 
12 is supplied over connection 124 to off-air demodulator 108, which communicates 
over connection 123 with MPEG-2 encoder 109. MPEG-2 encoder 109 receives the 
off-air broadcast signal and converts it into a digital video format in accordance with 
the MPEG-2 video standard for the preferred embodiment. Although illustrated as 
single items, in reality, a plurality of off-air demodulators and MPEG-2 encoder are 
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employed. The MPEG-2 signal is supplied over connection 122 to MPEG-2 
multiplexer 111. MPEG-2 multiplexer 1 1 1 supplies the now MPEG-2 encoded off-air 
video signal over connection 121 to video control shelf 200. Connection 121 is 
illustratively another connection capable of delivering an MPEG-2 digital video 
signal, and is illustratively a DS-3 connection. 

Also connected to video control shelf 200 over connection 1 1 7 is system 
management workstation (SMW) 325. SMW 325 provides supervisory, management 
and control functions for TPCC 100 and will be discussed in detail with reference to 
Fig. 8. SMW 325 also connects to ATM switch 102 over connection 116, whereby 
management and control information is sent through ATM switch 102 and over 
connection 14 to SONET add/drop mux 106 for placement on SONET network 150. 
In this manner, management and control information is delivered to and received from 
central office 400. 

Video control shelf 200 inserts local program guide and control information 
into the digital video program by replacing a null MPEG-2 packet that is not used to 
transport video data. This local program guide information comes from SMW 325, 
the workstation responsible for monitoring and controlling the digital video and data 
delivery system. The program guide database is received from a centralized provider 
or may be locally generated. Video control shelf 200 can also be used to insert 
software update data for customer premise information by replacing a null MPEG-2 
packet that is not used to transport video data. The video programming with the 
newly inserted data then enters the telephone company (telco) private SONET 
network 150 via SONET add-drop mux 106. Router 101 isolates the internal telco 
data delivery network from the Intemet, routing only the appropriate packets to ISP 
14. ATM switch 102 provides a robust interconnection to the switches in the 
individual central offices 400 providing Intemet data to the system. Furthermore, 
router 101 and ATM switch 102 exchange Internet data in both upstream (from 
customer premise toward central office to TPCC) and downstream (from TPCC to 
central office, to customer premise) directions. 
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Fig. 5 is a block diagram illustrating the video control shelf 200 of Fig. 4. 
Video control shelf 200 includes a plurality of video control module pairs 250 and 
shelf processor module pair 300. In the discussion and figures to follow reference is 
made to module pairs. The term module pairs refers to an active and a standby 
module each configured to execute the functionality described. Each module of the 
pair is supplied with the input signal and each module is capable of supplying the 
output signal. The standby module will perform the functionality described if the 
active module experiences a failure. Furthermore, in the discussion to follow, the 
term "hotswap" refers to the ability to replace a module in a system without removing 
power to the system in which the module is installed. 

Satellite receiver 104, which includes a plurality of MPEG-2 multiplexers 111, 
receive network feeds from content provider 1 1 over connection 126. MPEG-2 
multiplexers 1 1 1 interface a plurality of DS-3 connections 11 8a through 1 18n each 
DS-3 having a spare, with video control shelf 200. Each DS-3 connection 118 
connects to a video control module 250, with each DS-3 spare connecting to a spare 
video control module 250. Video control module pair 250 includes an active video 
control module and a standby video control module, with a spare DS-3 connected to 
the standby video control module. MPEG-2 multiplexer 1 1 1 also connects via a DS-3 
cormection to a video control module pair 250. 

The output of each video control module pair 250 is provided via DS-3 
connection 1 19 to SONET add-drop multiplexer 106. Also included in video control 
shelf 200 is shelf processor module pair 300. The operation of video control module 
250 will be discussed in detail with reference to Fig. 6 and the operation of shelf 
processor module 300 will be discussed in detail with reference to Fig. 7. The digital 
video and data delivery system of the present invention currently supports up to eight 
digital video program groups, however, it is foreseeable that in the future additional 
program groups may be supported, A program group is defined as a single MPEG-2 
transport stream containing nimierous channels carried over a single network 
connection, such as a DS-3 or OC-3 connection. Thus, up to eight program groups are 
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supported by video control shelf 200. This means that each DS-3 connection, for 
example 1 18 and 1 19, carries one program group. 

A program group transported via DS-3 can contain roughly ten channels, while 
a group transported via OC-3 can contain roughly 35 channels. This indicates a 
system channel capacity of 80 channels for implementations using DS-3, and a 
maximum channel capacity of approximately 280 channels for systems implemented 
using the OC-3 connection. At least one group (and possibly more) will contain local 
channels, as illustrated by DS-3 connection 121 and DS-3 connection 123 containing 
video control module pair number 8 to SONET add/drop multiplexer 1 06. The 
remaining connections comprising, for this preferred embodiment, seven program 
groups will contain video programming from other sources as illustrated by DS-3 
connections 118 and 1 19. Program groups can be multiplexed together to increase 
overall channel capacity. For example, two half-full DS-3 groups can be combined 
together, freeing an entire DS-3 for additional programming. 

Fig. 6 is a block diagram illustrating the video control module 250 of Fig. 5. 
Video control module pair 250 receives the DS3 data streams on lines 1 1 8a and 1 1 8b, 
the input on line 1 1 8a being the primary and the input on line 1 1 8b being the 
secondary or redundant video supply corresponding to that illustrated in Fig. 5. These 
data streams contain the encoded MPEG-2 video streams. Video control module 250 
replaces null MPEG-2 packets in each program group with control and software 
update data. The program group including additional data, such as the program guide 
and the software update data is then sent via both DS-3 links 1 1 9a and 1 1 9b to video 
network interface shelf 450. Each video control module 250 contains a primary DS3 
line termination and receiver 251a and a redundant DS3 line termination and receiver 
device 25 1 b. The DS3 line receivers extract the payload data from the incoming bit 
stream and prepare the information for delivery to the control data insertion block 
256. Both receivers 25 1 a and 25 lb are always active allowing redundancy at the 
input link. The onboard supervisory module 252 monitors the status of the receivers 
over connections 259a and 259b and determines which line receiver signal will be 
used to drive the serial feed to the control data insertion block 256 over connection. 



14 



wo 99/23774 



PCT/US98/23497 



Supervisory module 252 sends control signals to primary DS3 line termination and 
receiver 25 1 a and a redundant DS3 line termination and receiver device 25 1 b over 
connections 259a and 259b respectively. The control data insertion block 256 is 
responsible for inserting local control data into the incoming MPEG-2 stream arriving 
from the content provider. Program guide data and possibly software update data for 
the INI 1350 is inserted by replacing null packets with the necessary data. The serial 
data received from the control data insertion block 256 contains both the MPEG-2 
video data and the additional control data. Control data, software update data and 
program guide data are all inserted into the program group in the same way. The new 
data stream is used as input over connections 262a and 262b to program output block 
261, which contains primary DS3 line transmitter 257a and redundant DS3 line 
transmitter 257b, which form a redundant link to the video network interface shelf 
450. If supervisory module 252 has asserted the output enable line 263, both primary 
DS3 line transmitter 257a and redundant DS3 line transmitter 257b are enabled. The 
primary video signal is output on line 1 19a and the redundant video signal is output 
on line 119b. 

Supervisory module 252 is responsible for proper operation of video control 
module 250. Supervisory module 252 performs set up and initialization of all other 
functional blocks on video control module 250 and monitors the status of each 
ftmction. Supervisory module 252 maintains communication with shelf processor 
module 300 and is responsible for active/stand-by redundancy control. If the video 
control module 250 experiences a catastrophic failure, supervisory module 252 
changes the module to the inactive state and alerts the shelf processor 300 over 
connection 269 the next time it is polled for status information. Because the video 
control module 250 is designed for active/stand-by redundancy, they are expected to 
be installed in pairs. Each monitors the fault indicator of its redundant neighbor over 
cormection 271 and will go active immediately upon failure of the active module. 
Voltage management module 254 is responsible for hotswap capabilities and power 
management. Hotswap capability refers to the ability to remove one of a pair of failed 
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video control modules without powering down the video control shelf in which they 
reside. 

Fig. 7 is a schematic view of the shelf processor module 300 of Fig. 5. Shelf 
processor module 300 provides redundant control and monitoring of the shelf in 

5 which it is installed. Shelf processor modules reside in multiple applications and 

include firmware which enables the operation of the shelf processor module for each 
particular application for which it is installed. For example, while the same shelf 
processor module resides in both the video control shelf 200 and in the video network 
interface shelf 450 (to be described with reference to Fig. 10), the shelf processor 

10 modules perform different functions depending on the shelf in which installed. These 
different operations are determined by the firmware installed in the shelf processor 
module and based upon in which application the module is installed. Each shelf 
processor module will include firmware for all possible applications. The firmware 
installed in each shelf processor module will determine the shelf in which the module 

15 is installed and wall execute the appropriate segment of the fumware code. Shelf 

processor module 300 passes configuration information to and from the central office 
master (COM) workstation 650 over connection 303 to any circuit board installed in 
the same shelf and gathers status regarding all boards installed for transfer back to the 
COM 650. Shelf processor module 300 stores configuration data for each board, 

20 detects the installation and replacement of boards and configures new boards 

automatically without COM 650 involvement. Shelf processor module 300 is used in 
many applications and in all shelves of the digital video and data delivery system and 
contains appropriate software and firmware to execute different functionality 
depending upon where it is installed. Shelf processor module 300 configures itself 

25 appropriately during power up based on the shelf type and/or shelf address read from 
the system backplane. The shelf address may be a value assigned by the central office 
master workstation (to be described with reference to Fig. 9) or may be manually 
selected through the use of a sv/itch. Two shelf processor modules will be installed in 
each shelf Only one will be active at a time, the other remains in stand-by mode. 

30 The stand-by shelf processor will have access to all the status and configuration 



16 



wo 99/23774 



PCT/US98/23497 



information for the shelf and will be prepared to automatically take over from the 
active shelf processor if the active shelf processor experiences a failure. The shelf 
processor consists of four main functional blocks, the supervisory- module 301, the 
slave interface module 302, the Ethernet module 304, and the voltage management 

5 module 306. The supervisory module 301 is an embedded microprocessor v/ith its 

associated memory and supporting logic. Supervisory module 301 supports 
redundancy by way of several links to its sibling shelf processor including hardware 
indicators for various faults and board presence. Also included in supervisory module 
301 is a bank of dual ported registers for communicating state, self-test results, slave 

10 board reset status, and other status information. It is capable of resetting and being 

reset by its sibling shelf processor module 300. It uses a bi-directional serial bus to 
communicate command and status with the slave boards in the shelf. 

The slave interface module 302 detects the presence of each of the slave 
boards in the shelf, and whether a board has been removed and reinstalled. A slave 

15 board is any board that is located within any of the shelves described herein. Slave 

interface module 302 has a reset line for each slave board which can be pulsed to reset 
the board or held to completely disable it. Ethernet module 304 provides the means 
by which shelf processor module 300 communicates with COM workstation 650 via a 
lObase T Ethernet port over connection 303. Voltage management module 306 

20 allows live insertion and removal of shelf processor module 300. It provides 

controlled ramp up of +5 VDC and +3.3 VDC power. It also provides an output to 
disable backplane input/output until power has stabilized. It also automatically shuts 
off power to the board and indicates a fault when it detects an over current condition. 
Voltage management module 306 also interrupts board power when the reset line 307 

25 is asserted. 

Fig. 8 is a flow diagram illustrating the architecture, functionality and 
operation of a possible implementation of the system management work station 
(SMW 325) functions of Fig. 4. In this regard, each block represents a module, 
segment, or portion of code, which comprises one or more executable instructions for 

30 implementmg the specified logical function(s). It should also be noted that in some 

17 



wo 99/23774 



PCT/US98/23497 



alternative implementations, the functions noted in the blocks may occur out of the 
order noted in Fig. 8. For example, two blocks shown in succession in Fig. 8 may in 
fact be executed substantially concurrently or the blocks may sometimes be executed 
in the reverse order, depending upon the functionality involved, as will be further 
clarified below. In block 326 the user interface allows access to SMW subscriber 
database view 334, central office master (COM) status, or program guide utility. User 
interface provides the interface for adding and administering subscribers, providing 
the interface with which to view the distributed COMs and monitor central office 
equipment, provides interface for channel maps and program guides, and provides the 
graphical user interface via, for example, Java and hypertext mark-up language 
(HTML). Other programming standards may be used to implement the graphical user 
interface, Java and HTML chosen for the preferred embodiment due to the advantage 
of portability to many different hardware platforms which may be used to implement 
the system management workstation and the central office master workstation. The 
central office master, or COM workstation, is the computer system that resides within 
each telco central office 400, and will be described in detail below. 

In block 327, the subscriber setup and control module maintains the master 
database of subscriber information including the following. Video channel access 
authorizations, Internet service authorization, account activity (pay per view (PPV) 
information) and service enabling and disabling. The subscriber setup and control 
block 327 also distributes and reconciles localized copies of the database to relevant 
COMs for universal access adapter (UAA) configuration and PPV information. Also 
interfacing with user interface 326 and subscriber setup and control module 327 is 
COM status display module 328. COM status display module 328 provides overall 
status of all COMs and allows individual detailed COM status views. 

Module 329 includes channel mapping and program guide information which 
generates basic channel mapping information for distribution to each COM and 
generates program guide infonnation for distribution to each COM. Subscriber setup 
and control module 327 also interfaces with SMW database view 334, which in turn 
interfaces with telco subscriber database 33 1 and SMW database 332. SMW database 
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view 334 also interfaces to subscriber database interface module 337. Telco 
subscriber database 33 1 contains customer information including customer name and 
address and SMW database information contains customer identification information 
pertaining to customer services, pay per view information and channel viewing 
information. Subscriber database interface 337 converts a subscriber database and 
billing information into a format that is readable by the telco's local billing system. 
Hierarchical COM management module 333 communicates with subscriber set up and 
control module 327, COM status display module 328 and channel mapping and 
program guide information module 329. Hierarchical COM management module 333 
manages the bi-directional transfer of information to distributed COMs and 
illustratively communicates with remote COMs 336, 338, and 339, SMW also 
collects statistics from the central office master workstations regarding users' channel 
viewdng selections. 

Turning now to Fig. 9, shown is a schematic view illustrating the architecture 
of central office 400. Central office 400 receives the combined digital video and data 
signal over SONET network 150 into SONET add-drop multiplexer 401 . SONET 
add-drop multiplexer 401 exchanges plain old telephone service (POTS) information 
with PSTN (public switched telephone network) voice switch 409 over connection 
408. SONET add-drop multiplexer 401 also exchanges data information over 
connection 407 with switch 406. SONET add-drop multiplexer 401 communicates 
video data over connection 402 to video network interface shelf (VNIS) 450. 
Illustratively, connection 402 is shown as a single connection, however, connection 
402 is in reality a plurality of DS-3 communication channels each carrying one 
program group of the compressed digital video content as described above. VNIS 450 
performs a protocol transformation in order to convert the received video data into a 
standard, compressed digital video transport format, for example but not limited to, 
digital video broadcast-asynchronous serial interface (DVB-ASI). VNIS 450 is 
comprised of a plurality of video network interface modules and will be described in 
detail with reference to Figs. lOA and lOB. 
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The output of VNIS 450 is communicated on connection 404, which again 
represents a plurality of channels, each containing one of the video program groups, to 
video distribution shelf 500. Video distribution shelf 500 is responsible for 
distributing the digital video program groups with redundancy to all access shelves 
550, Video distribution shelf 500 will be described in detail with reference to Figs. 
1 1 A-1 IE and access shelf 550 will be described in greater detail with reference to 
Fig. 12. Video distribution shelf 500 supplies eight active program groups and eight 
spare connections over connection 41 7 to access shelf 550. Connection 417 can be 
any cormection that provides the needed capacity to carry both the active and spare 
program groups. 

Access shelf 550 communicates over connection 419 with low pass filter shelf 
600, the operation of which will be described in detail with reference to Fig. 12. Low 
pass filter shelf 600 communicates over communication channel 16 to customer 
premise 1300. Illustratively, communication channel 16 may be a digital subscriber 
line (DSL) communication channel which, in addition to the digital video signal being 
delivered to customer premise 1300, includes bi-directional Internet data (or any data), 
and includes POTS service to support telephone communication between customer 
premise 1300 and central office 400. It is important to note that while described as 
using a DSL communication channel, channel 16 can be any communication channel 
that supports the communication of compressed digital video, bi-directional Internet 
data and POTS. Other communication channels, for example but not limited to a 
wireless communication channel such as an LMDS (local multipoint distribution 
system), may be used to communicate between central office 400 and customer 
premises 1300. 

Low pass filter shelf 600 communicates POTS information over connection 
420 to PSTN voice switch 409, which in turn communicates telephone service over 
connection 408 through add-drop multiplexer 401 to telco SONET Network 150. 

Also included at central office 400 is central office master (COM) workstation 
650. COM workstation 650 communicates control information over connection 41 1 
to switch 406, and communicates over connection 414 to VNIS 450 in order to 
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communicate control data information relative to the operation of the network. COM 
workstation 650 also communicates over connection 418 to video distribution shelf 
500 and over connection 416 to access shelf 550. COM workstation 650 is 
illustratively the management workstation that runs the software that controls the 
operation of the devices located at central office 400, and that enables the present 
invention to operate. The operation of COM workstation 650 will be discussed in 
detail with reference to Fig. 1 5. 

Fig. 1 OA is a schematic view illustrating the video network interface shelf 450 
of Fig. 9. Central office 400 includes SONET add-drop multiplexer 401 which 
receives the combined video and data signals from SONET network 150. Central 
office 400 includes video network interface shelf 450, which includes video network 
interface module 700 pairs, video output module 750 pair, and shelf processor module 
300 pairS. Each video network interface module pair includes an active video 
network interface module 700 and a spare, or stand-by, video network interface 
module 700. Each video network interface module (VNIM) 700 receives a video 
program group on DS3 line 402. Each program group is supplied simultaneously to 
the active VNIM and the stand-by VNIM. Illustratively, each video network interface 
shelf 450 includes eight pairs of video network interface modules 700, each video 
network interface module pair receiving the complete program group via a DS3 
connection. Each video network interface module pair 700 provides a complete 
program group to broadcast backplane 1200. Broadcast backplane 1200, the operation 
of which wall be described in detail with reference to Fig. 13, is in communication 
with video output module pair 750. Video output module pair 750 supplies the 
program data on connection 404 to video distribution shelf 500 of Fig. 9. The content 
supplied on connection 404 can be in the form of DVB-ASI content. 

Video network interface shelf 450 also includes shelf processor module pair 
300, the operation of which is similar to that as described above. The eight pairs of 
video network interface modules 700 receive the video signal in DS3 format and drive 
the eight program groups onto broadcast backplane 1200 as parallel data. 
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Fig. 1 OB is a block diagram illustrating the video network interface module 
700 of Fig. IDA. The video network interface module 700 receives one program 
group of digital video programming over redundant DS-3 links 402a and 402b. The 
DS-3 payload (MPEG-2) data is extracted from the incoming signal and inserted onto 
5 broadcast backplane 1200 for delivery to video output module 750. Video network 
interface module 700 is designed for active/standby redundancy, contains circuitry to 
allow hotswap, and communicates with the video network interface shelf processor 
module 300 for various control purposes. Dual DS-3 signals are presented to each 
module at the input for link redxindancy. Video network interface module 700 

10 includes primary DS-3 line termination and receiver 701a and redundant DS-3 line 

termination and receiver 701b. The DS-3 line receivers extract the payload data from 
the incoming bit stream and prepare the content for delivery to the parallel video bus 
driver 706. Both receivers 701a and 701b are always active, allowing redundancy at 
the input link. Supervisory module 704 monitors the status of the receivers 701a and 

15 701b over connections 708a and 708b, respectively, and determines which line 

receiver signal will be used to drive the serial feed to the parallel video bus driver 706. 
Supervisory module 704 communicates control information to DS-3 line termination 
and receiver 701a over connection 714a and conununicates control information to DS- 
3 line termination and receiver 701b over connection 714b. The parallel video btis 

20 driver 706 receives serial data from one of the DS3 line receivers 701a or 701b, over 
connection 709a or 709b, depending upon which DS-3 line termination and receiver 
device is active, as determined by the on board supervisory module 704. The serial 
data is reorganized into the original 8 bit byte format wherein two control data bits are 
concatenated with the original byte. Differential signaling, and in the preferred 

25 embodiment, low voltage differential signaling (LVDS) line drivers (not shown) 
within parallel video bus driver 706, send this 10-bit "word" to the 20 differential 
output lines on parallel video bus driver 706 if the supervisory module 704 allows the 
drivers to be activated. 

Supervisory module 704 is responsible for proper operation of the video 

30 network interface module 700. It accomplishes set up and initialization of all 
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functions on the module. Supervisory module 704 also monitors the status of each 
function. The supervisory module 704 maintains communication with shelf processor 
300 and is responsible for active/stand-by redundancy control. Should the video 
network interface module 700 experience a failure, supervisory module 704 alerts 

5 shelf processor module 300 and causes video network interface module 700 to 
become inactive. Because the video network interface module is designed for 
active/stand-by redundancy, they are typically installed in pairs, each monitoring the 
fault indicator of its redundant neighbor over connection 711, which will cause it to 
go active immediately upon failure of the active module. Similarly, supervisory 

10 module 704 supplies its fauh status over connection 712 to its counterpart supervisory 

module in its neighbor video network interface module. Voltage management module 
702 is responsible for hotswap capability and power management in accordance with 
that described above. 

Fig. 1 1 A is a schematic view illustrating the video distribution shelf 500 of 

15 Fig. 9. Central office 400 includes video distribution shelf 500, which includes video 

input module pairSOO, multiple video output module pair 850, remote video output 
module pair900, and shelf processor module pair300. Video input module 800 pair 
receives the DVB-ASI format video signal as input over connection 404. While 
illustrated as a single pair, there are in fact eight video input module pairs in diis 

20 . preferred embodiment, corresponding to the eight DVB-ASI input signals 404, and 
the eight DVB-ASI spare input signals. Each active video input module 800 receives 
the active program group while the spare video input module receives the program 
group over DVB-ASI spare connection. Each video input module 800 supplies a 
program group onto broadcast backplane 1200. Multiple video output module 850 

25 pair receives the program group content from broadcast backplane 1200 and provides 
as an output two copies of each program group. Thus, each multiple video output 
module 850 drives 16 discreet DVB-ASI outputs 501. The spare module drives the 
spare outputs at all times. Remote video output module 900 pair can be used in place 
of multiple video output module 850 to provide connectivity to digital loop carriers 

30 (DLCs). The remote video output module 900 outputs a single multiplexed copy of 
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the program groups onto a single fiber optic cable by multiplexing the eight program 
groups into a serial bit stream at approximately 2.488 Gigahertz (GHz). The spare 
module drives the spare output onto a spare fiber optic cable at all times. 

Shelf processor module 300 pair is also included in video distribution shelf 
500, the operation of which was described above. Each video input module 800 pair 
receives up to eight video program groups in DVB-ASI format. The multiple video 
output modules 850 drive redundant video outputs that provide video data to multiple 
access shelves 550 (to be discussed with reference to Fig. 12). If employed, remote 
video output module pair 900 multiplexes and transmits all of the digital video 
program groups to an access shelf 550 via fiber optic link. Shelf processor module 
300 provides redundant control and monitoring of die shelf 

Fig. 1 IB is a block diagram illustrating the video input module 800 of Fig. 
1 1 A. Video input module 800 receives all eight program groups in DVB-ASI format 
over connections 404. The data is converted into LVDS parallel form (with extra 
control bits added) and made available, via the particular shelf backplane, to all other 
modules connected to broadcast backplane 1200. Video input module 800 is designed 
for active/standby redundancy, contains special circuitry to allow hot swap, and 
communicates with shelf processor module 300 for control purposes, DVB-ASI 
receiver 801 receives input from eight individual channels 404. Each input line 404 is 
DVB-ASI compliant. The video data on lines 404 is forwarded from DVB-ASI 
receiver 801 to LVDS driver module 802 over connection 807. LVDS driver module 
802 converts the serial data received fi-om DVB-ASI receiver 801 to parallel form. 
Special control bits are added to each byte and the data is byte aligned (to be 
described with reference to Fig. 20). 

When supervisory module 806 asserts the output enable signal on line 808, 
LVDS drivers for all 160 lines are enabled and all eight program groups are driven 
onto broadcast backplane 1200 where they are simultaneously made available to all 
other modules on broadcast backplane 1200. 

Supervisory module 806 is also responsible for proper operation of video input 
module 800. Supervisory module 806 oversees set up initialization of all fimctions 
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performed on video input module 800 and monitors the status of each function. 
Supervisory module 806 maintains communication with shelf processor module 300 
and is responsible for active standby redundancy control. Should video input module 
800 experience a failure, supervisory module 806 alerts shelf processor module 300 
and causes video input module 800 to immediately go inactive. Because video input 
module 800 is designed for active/standby redundancy, it is expected to be installed in 
pairs. Each monitors the fault indicator of its redundant neighbor over connection 
809, and supplies its own fault information over connection 8 1 1 , and will go active 
immediately upon failure of the active module. Voltage management module 804 is 
responsible for hotswap capability and power management in accordance with that 
described above. 

Fig. lie is a schematic view illustrating an alternative distribution scheme to 
the video input module of Fig. 1 IB. Remote video input module 825 can be used as 
an alternative to video input module 800. Remote video input module 825 receives a 
single multiplexed copy of eight 10-bit parallel video program groups along with 
framing and overhead from a single optical fiber connection 836. The framing is 
detected and the data is demultiplexed into die eight 10-bit parallel video program 
groups. A spare module will demultiplex the spare fiber input at all times. One of the 
two modules will drive the program groups onto broadcast backplane 1200. 

Optical receiver 826 converts the optical data stream on connection 836 into 
an electronic data stream containing the video programming on connection 842. 
Clock regeneration and data sync 827 regenerates the serial clock from the serial data 
stream and resynchronizes the data to this clock. A 2.488GHz clock signal is supplied 
on connection 844 and the video programming is supplied over connection 843. A 
1:16 demuhiplexer/receiver and frame detector 828 detects the start of frame bits and 
demultiplexes the data into 1 6-bit words. A 1 55.5 MHz clock signal is supplied over 
connection 845, the video programming is supplied over connection 846, and frame 
control information is exchanged with payload extraction device 829 over connection 
847. Payload extraction device 829 strips off the framing and overhead bits leaving 
the video program groups on connection 837. Transmit first-in first-out (FIFO) buffer 
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83 1 buffers the eight program groups on connection 837 in a first-in first-out 
arrangement in order to resynchronize the parallel transmit data rate. LVDS video 
drivers 832 drive the eight program groups onto broadcast backplane 1200 over 
connections 838. Illustratively, the optical connection over which the multiplexed 
program groups are transported should have sufficient capacity to carry the data such 
that the program groups may be transported without loss of any infonnation. 

Supervisory module 834 communicates with shelf processor module 300 to set 
a fault bit over connection 833a, and reads a neighbor fault bit over connection 833b. 
Supervisory module 834 also enables the LVDS video drivers 832 over connection 
839 when appropriate. Voltage management module 841 is responsible for hotswap 
capability and power management in accordance with that described above. 

Fig. 1 ID is a block diagram illustrating the multiple video output module 850 
of Fig. 1 1 A. Multiple video output module 850 receives all eight program groups 
from video input module 800 over broadcast backplane 1200. The eight program 
groups are replicated n times and delivered out of the video distribution shelf 500 on 
lines 501 in DVB-ASl format. Multiple video output module 850 is designed for 
active/stand-by redundancy, contains special circuitry to allow hotswap, and 
communicates with the video distribution shelf processor module 300 for various 
control purposes. 

Parallel video bus receiver 851 contains LVDS receivers for 160 signals, eight 
program groups consisting of 20 signals per program group. It receives the video data 
from the video input module 800 via broadcast backplane 1200. DVB-ASI drivers 
856a-856n are responsible for creating a DVB-ASI compliant output on line 501 for 
each of the program groups. Each connection 857a through 857n includes a serial 
data stream containing a program group. Each program group is carried on one output 
connection, therefore each output module contains eight outputs. Any number of 
DVB-ASI driver modules 856 may exist on a multiple video output module 850, 
allowing for scalability of the entire system. 

Multiple video output module 850 is designed for active/stand-by redundancy. 
Supervisory module 854 is responsible for proper operation of the multiple video 
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output module 850. Supervisory module 854 provides set up and initialization of all 
other functions on the module and monitors the status of each function. Supervisory 
module 854 maintains communication with shelf processor module 300 and is 
responsible for active/stand-by redundancy control. If multiple video output module 
850 experiences a failure, supervisory module 854 alerts shelf processor module 300 
over connection 858 and immediately goes inactive. Similarly, if supervisory module 
854 detects a failure of its counterpart multiple video output module over connection 
859, it will immediately become active. Because multiple video output module 850 is 
designed for active/stand-by redundancy, both cards of any pair will always be driving 
a set of redundant output signals. Voltage management module 852 is responsible for 
hotswap capability and power management in accordance with that described above. 

Fig. HE is a schematic view illustrating a remote video output module of Fig. 
1 lA. Remote video output module 900 outputs a single multiplexed copy of eight 10- 
bit parallel video program groups along with framing and overhead onto a single fiber 
optic link for transmission to digital loop carriers (DLCs). A spare module will drive 
the spare output onto a spare fiber optic link at all times. LVDS video receiver 901 
will receive the eight program groups and output a video signal over connection 914 
to receive FIFO buffer 904. Since the serial transmit rate and the parallel receive data 
rate are not equivalent, the eight program groups parallel data is buffered in receive 
FIFO buffer 904 to resynchronize to the serial data rate. Receive FIFO buffer 904 
supplies the video programming over connection 916, supplies FIFO flags over 
connection 918, and receives FIFO control signals from framer 906 over connection 
917. 

Framer 906 organizes the incoming data into frames and adds the framing bits 
to the start of the frame. Extra data bytes v^U be added to the fi-ame if necessary to 
synchronize the data rates. The data is transferred out of framer 906 over connection 
919 in 16-bit words. The 16-bit parallel data stream fi-om framer 906 is multiplexed 
into a serial data stream for transmission by 16:1 multiplexer/transmitter 907 over 
connection 91 1 to optical transmitter 908. Optical transmitter 908 takes the serial data 
stream on connection 91 1 and converts it into an optical stream for transmission over 
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connection 912 on an optical fiber. Supervisory module 909 and voltage management 
device 902 function as described above. 

Fig. 12 is a schematic view illustrating the access shelf 550 and the low pass 
filter module 600 of Fig. 9. Referring back to Fig. 1 1 A, the output of each multiple 

5 video output module 850 on connection 501, is supplied to video input module 950, 

which is also implemented in this preferred embodiment in pairs, of Fig. 12 on 
connection 501. The content on connection 501 is in DVB-ASI video format. A total 
of 16 DVB-ASI video signals are supplied to eight video input module 950 pairs. The 
pair of video input modules 950 determines which input signals (main or spare) are 

10 valid and drives the program groups onto broadcast backplane 1200, Access shelf 550 
further includes universal access adapter module (UAA) 1000. Each UAA module 
1000 receives all of the available program content from broadcast backplane 1200. 
UAA module 1000 also includes central office (CO) framer 1 100, the operation of 
which wall be discussed in detail with respect to Fig. 19. 

15 The broadcast backplane, effectively extends the availability of digital video 

content right up to the communication channel that links central office 400 to 
customer premises 1300. All available program content is always available on 
broadcast backplane 1200. Broadcast backplane 1200 simultaneous makes available 
all of the digital video content to all users. In this manner, the present invention 

20 allows, for example, all users of the system to simultaneously receive the same 

programming content with virtually no impact to the quality of the signal, and without 
overloading the switching capability of the central ofBce, In the same manner it 
allows all users to view different programming content v^thout overloading the 
system. The broadcast backplane effectively extends the availability of digital video 

25 content right up to the communication channel that links central office 400 to 

customer premise 1300. It effectively broadcasts all channels to the physical point 
where the channel selection process is performed in the access shelf 550. Hence, there 
is no need to broadcast all channels to the customer premise. 

UAA module 1000 provides video and data services to multiple customers. 

30 As the system is expanded, additional access shelves and UAAs are added to serve the 
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new customers. In the access shelf 550, redundant video input modules are used to 
receive the eight video program groups in DVB-ASI format. The video programming 
is made available to each UAA module 1000 over broadcast backplane 1200. This is 
a unique feature in that hundreds of video programming channels are available on 
broadcast backplane 1200 to each universal access adapter module 1000. In this 
manner, an end user at a customer premise 1 300 can have a choice of receiving any of 
the available programming content, so long as that customer is authorized for the 
requested channel. In this maimer, an end user has access to all available 
programming content without the necessity of sending the entire programming data to 
each customer location. This unique feature of the present invention allows the use of 
a conventional copper wire pair, or any communication medium or methodology 
capable of supporting the transport of compressed digital video, bi-directional 
Internet data and POTS, between central office 400 and customer premises 1300 to 
provide digital video programming to each customer on demand. The digital video 
channels are effectively broadcast within the access shelf to all UAA modules 1000. 

Furthermore, in conjunction with the delivery of digital video to each 
customer, bi-directional data exchange (i.e., an Internet connection) and POTS are 
simultaneously available on the same channel. 

UAA module 1000 provides the video program content and the Internet data 
over connection 419 to low pass filter shelf 600. Low pass filter shelf 600 contains 
multiple low pass filter modules 1050, each configured to receive the output of a 
universal access adapter module. Each low pass filter module 1050 combines the 
video program content and the data with POTS information and directs it to a 
customer premise over communication channel 16. As presently configured, each 
UAA module 1000 can serve four customer interface lines, however, it is foreseeable 
that advances in technology will enable additional capacity, without departing from 
the scope of the invention. 

The UAA module 1000 receives digital video content from the broadcast 
backplane 1200 and delivers the video programming to the customer as requested. 
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Internet data for all four customers enters through lOBase T connector on access shelf 
550 that houses UAA module 1000. 

Fig. 13 is a schematic view illustrating additional detail of access shelf 550 of 
Fig. 9. Fig. 13 specifically illustrates broadcast backplane 1200 containing eight 

5 program groups of video content distributed from video input module 950 to each 

universal access adapter module 1000. Broadcast backplane 1200 is formed by the set 
of eight digital video program groups. In a preferred embodiment, each program 
group transports MPEG-2 digital video data in parallel format. Broadcast backplane 
1200 connects to each universal access adapter module 1000 to allow all end users 

10 access to all available video programming. All available program content is always 
available on broadcast backplane 1200, Broadcast backplane 1200 simultaneously 
makes available all of the digital video content to all users. In this manner, the present 
invention allows, for example, all users of the system to simultaneously receive the 
same programming content and allows a large number of users to watch a variety of 

15 programs with virtually no impact to the quality of the signal, and without 
overloading the switching capability of the central office. 

Fig. 14 is a schematic view illustrating universal access adapter module 1000 
of Figs. 12 and 13. Universal access adapter (UAA) module 1000 provides digital 
video content and Ethernet data services to n subscribers using, in this preferred 

20 embodiment, asymmetric digital subscriber line (ADSL) technology. This technology 
includes rate adaptive digital subscriber line (RADSL) technology and any and all 
variations of xDSL technology. Furthermore, it is to be understood that any digital 
data transfer technology that can be accomplished over, for example but not limited 
to, a copper wire pair, or any transmission medium that can support the transfer of 

25 digital video signals, bi-directional Internet data and POTS, can be used without 

departing from the scope of the present invention. xDSL technology is used herein 
for illustrative purposes only. Illustratively, this preferred embodiment assumes that 
four customer premise locations can be served by one UAA module 1000. It is to be 
understood that future implementations may increase or decrease the number of 

30 customer premise locations served by each UAA module 1 000. In the preferred 
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embodiment, the UAA module 1000 accepts eight digital video program groups, 
however, it is foreseeable that in the future additional program groups may be 
supported. UAA module 1000 allows each subscriber to select a particular program 
from these program groups for viewing. Selection of a program for viewing is 

5 accomplished using a control channel in the xDSL link, herein illustrated as control 

channel 1011. By use of this control channel a subscriber indicates to central office 
400 via communication channel 16, a desire to receive a particular program. Note that 
the subscriber does not need to know which program group or program ID they are 
selecting. Program groups and program ID's are mapped to channel numbers by 

10 UAA 1000. In addition, control channel 1011 allows a subscriber to select the use of 
Ethernet data services. Ethernet data may be used in place of digital video 
programming, or in addition to digital video programming. The Ethernet data channel 
is designed to facilitate high bandwidth bi-directional access to the Internet through 
Internet service provider 14. 

15 LVDS video bus receiver 1009 receives the digital video program groups from 

broadcast backplane 1200 and converts the differential signals into single-ended 
signals. The single-ended signals are then sent over connection 1012 to multiplexer 
1008. Multiplexer 1008 accepts eight program groups and provides a single program 
group output on connection 1014 to each subscriber's CO framer 1 100. Mux 1008 

20 allows supervisory module 1007 to select the program group that contains the channel 
selected by a subscriber, and sends that program group to that subscriber's CO framer 
1 100. The operation of CO framer 1 100 will be discussed in detail with reference to 
Fig. 19. Mux 1008 can simultaneously serve up to n CO framers independently. 
Supervisory module 1007 writes the desired program group to be selected to a register 

25 in CO framer 1 100. CO framer 1 100 then instructs mux 1008 to select the appropriate 
program group from the input on connection 1012. CO framer 1 100 then selects a 
single program from the program group and forwards it to DSL transceiver 1001 for 
transmission to customer premise 1300 over communication channel 16. CO framer 
1 100 provides the interface to mux 1008. Alternatively, mux 1008 could provide an 

30 interface to supervisory module 1007, however, for the preferred embodiment, CO 
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framer 1 100 can more conveniently provide the interface to supervisory module 1007. 
Mux 1 008 selects one program group from the eight program groups on connection 
1012 and routes the selected program group to the appropriate CO framer 1 100. CO 
framer 1 100 then filters the desired program from the program group, combines it 
5 with Internet data from bridge 1004 and delivers the combined signal to a customer 

over communication charmel 16. Essentially, when a user selects a particular channel 
to view, supervisory module 1007 determines the program group and the packet 
identifiers (PIDs) within the program group that will extract the chosen channel. 
Supervisory module 1007 commands mux 1008, via CO firmer 1 100, to select the 

10 appropriate program group, and commands CO framer 11 00 to filter certain PIDs. In 
this manner the chosen program is delivered to the user. 

In order to gain access to Internet data, in this preferred embodiment, hub 
module 1006 accepts lObase T Ethernet data at 10 Mb/s on one port, and repeats the 
data to each of the other end ports. Bridge 1 004 provides an interface between lObase 

1 5 T (LAN) connection at hub module 1 006 and TTL level (WAN) data. Bridge 1 004. 

learns the addresses (i.e., the Ethernet, or medium access control (MAC) address) of 
equipment connected to the customer premises side of bridge 1004 and filters out data 
that does not correspond to those addresses. On the WAN side, it interfaces to CO 
framer 1 100 over connection 1016. There are one bridge and one CO fi-amer per 

20 subscriber. CO fi^er 1 100 sends and receives Ethernet data to and firom bridge 1004 
over connection 1016, and control channel data to and from supervisory module 1007 
over coimection 1011. It should be noted that Ethernet and the lObase T connection 
are merely possible implementations to achieve the transport of bi-directional Internet 
data between the central office and the customer premises. Any data can be 

25 transported using the concepts of the present invention. CO ft-amer 1 1 00 also accepts 
a digital video program group fi-om mux 1008 over connection 1014. CO framer 1 100 
outputs data to the xDSL transceiver 1001 and receives data fi-om DSL transceiver 
1001 at a rate which corresponds to the xDSL operating mode which has been 
selected (by supervisory module 1007). As mentioned above, a detailed description of 

30 the operation of CO framer 1 100 will be provided with reference to Fig. 19. xDSL 
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transceiver 1001 sends and receives TTL data to and from framer 1 100. xDSL 
transceiver 1001 also sends and receives xDSL data to and from each subscriber over 
connection 16. 

Supervisory module 1007 contains a microprocessor that is used to implement 
a control channel to and from the subscriber in order to communicate with shelf 
processor module 300 via a local bus 1017, and to provide control and read status on 
UAA module 1000. Typical functions of supervisory module 1007 include, but are 
not limited to, implementing a control channel (serial data port) to and from each 
subscriber via CO framer 11 00, determining the program identification and program 
group v^hich correspond to the channel selected by the subscriber, and sending the 
selected program group and program ID to the CO framer 1 100. Other functions 
include configuring the xDSL transceivers 1001, implementing a test port to test the 
xDSL transceivers, reading the card addresses, implementing a serial data port to 
communicate with shelf processor 300, monitoring the status of the xDSL transceiver 
1001 and bridges 1004, and resetting modules on UAA 1000. 

Voltage management module 1002 allows live insertion of UAA module 1000 
into a backplane without causing any errors on the backplane bus and without 
damaging any of the devices on UAA module 1000 or without damaging any devices 
on other parts plugged into the same backplane. A hotswap controller integrated 
circuit is used to perform this function and the integrated circuit provides a power on 
reset to the microprocessor system. 

Fig. 15 is a flow diagram of central office master workstation 650. Central 
office master work station 650 functions as follows. Block 651 provides the user 
' interface, which provides interface to subscriber database for UAA 1 000 assignments. 
User interface 65 1 also provides the interface with which to configure and monitor 
central office 400 equipment and provides a graphical user interface via, for example, 
Java and HTML. Subscriber database and control block 652 maintains a localized 
mirror image of the contents of the system management work station 325 database for 
subscriber information including the following: video channel authorizations, Internet 
service authorization, account activity (pay per view (PPV) info), service enabling and 
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disabling, and channel viewing statistics. Subscriber database and control block 652 
also allows the uploading of billing information and downloading of subscriber 
information. Subscriber database and control block 652 also configures the UAA 
1000 for service including initial set up and any change in service. Hardware set up 

5 and status display block 654 provides the following functions: initializing of central 
office 400 equipment, monitoring status of central office 400 equipment, including 
managing polling of shelf processor modules 300 for status information and managing 
polling of UAAs for pay per view buys. Hardware setup and status display block 654 
also provides access to a database of card configurations for rapid reconfiguration in 

10 case a large number of modules are simultaneously replaced. 

Embedded control network block 656 performs the function of communicating 
information between COM 650 and the central office 400 equipment. Embedded 
control network 656 also allows the application programmer interface (API) to define 
types of messages/commands that the system supports. System management 

15 workstation interface block 657 provides bi-directional communication between 

central office master work station 650 and the system management work station 325 
located in TPCC 100. COM 650 also provides the logic necessary for processing 
requests from users pertaining to desired program viewing, collecting statistics on 
users' channel viewing habits (z.e., which channels were viewed over a particular time 

20 period), and assigning communications ports on UAA modules 1000 over which 
digital video content, bi-directional Internet data and POTS is provided. 

Fig. 16 is a block diagram illustrating customer premise 1300. Digital video 
and data enters customer premise 1300 from central office 400 via communication 
channel 16. In the preferred embodiment, communication channel 16 is illustratively 

25 a digital subscriber line communication channel which also supports POTS 

communication. Alternatively, conmiunication channel 16 can be any communication 
channel capable of supporting the communication of compressed digital video, bi- 
directional Internet data and POTS, including but not limited to a wireless 
communication channel. Furthermore, the connections between INI 1350 and 

30 computer 1355, television 1365, and telephone 1360 may also be accomplished using 
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various connection methodologies including, for example but not limited to, wireless 
technology. 

Communication channel 16 connects to intelligent network interface (INI) 

1350. Computer 1355, television 1365, and telephone 1360 are illustratively 

5 connected to INI 1350. INI 1350 may also support additional POTS communication 
lines 1353a and 1353b, which may also be in the form of a digital signal. The 
architecture and operation of INI 1350 will be discussed below. 

Fig. 17A is a schematic view illustrating the intelligent network interface (INI) 

1350 of Fig. 16. INI 1350 includes RADSL (rate adaptive digital subscriber line) 
10 modem 1351 connected to communication channel 16. While illustrated using 

RADSL modem 1351, the digital video and data delivery system of the present 
invention can employ any communication technology for communicating between 
customer premise 1300 and central office 400. Also connected to RADSL modem 

1351 is telephone 1360. RADSL modem 1351 also supports additional POTS devices 
15 over connections 1353a and 1353b, which may be in the form of digital service. 

Processor 1354 connects to IR remote control interface 1358, RADSL modem 

1351, CP framer 1400, MPEG-2 chip set 1356, and graphics processor 1357. 
Processor 1354 controls the operation of INI 1350 in order to provide a video and 
audio television signal from MPEG-2 chip set 1356 to television 1365, and data from 

20 Ethernet interface 1352 to computer 1355 over lObase-T Ethernet connection 1359. 

Processor 1 354 also provides a serial data connection for debugging and maintenance, 
and may also provide a connection for low data rate devices, for example but not 
limited to utility or alarm monitoring. Processor 1354 also connects to IR remote 
control interface 1358. 

25 Referring now to Fig. 17B, IR remote control interface 1358 (contained v^thin 

INI 1350) allows bi-directional communication of RF information via the dwelling RF 
distribution system 1361 with one or more IR remote transceivers 1362. An IR 
remote transceiver 1362 can be located at each viewing/controlling location. 

Fig. 17C is a schematic view illustrating an IR remote transceiver 1362 of Fig. 

30 17B. The communication of RF information is accomplished by converting the 
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received IR communications from a handheld remote control (not shown), received by 
IR receiver 1367b. The IR receiver 1367b should be constructed so as to accept all 
Icnown carrier frequencies, for example, in the range of 32 to 40 KHz, and all codes 
The envelope of the received signal is used to control, in the preferred embodiment, a 
400 MHz frequency shift keying (FSK) transmitter 1363a, which transmits the signal 
over the dwelling RP distribution system 1361 to the INI 1350 via main RF signal 
path 1374. FSK transmitter 1363a and FSK receiver 1366b (and FSK receiver 1363b 
and FSK U-ansmitter 1366a of Fig. 17D) connect to main RF signal path 1374 through 
connection 1377, which is illustratively any connection that can successfully couple 
the respective transmitters and receivers to main RF signal path 1374. This link may 
be achieved via a 75 ohm coaxial cable, or via other ways, for example but not limited 
to a wireless connection. Also included is 360 MHz FSK receiver 1366b and IR 
emitter 1367a, which should be of sufficient power to control devices via an IR signal. 

Fig. 1 7D is a schematic view illustrating the IR remote control interface 1358 
of Fig. 1 7 A. IR remote control interface 1358 decodes the information received over 
main RF signal path 1374 in transceiver controller 1372 and passes a digital word to 
processor 1354 (Fig. 17A) via connection 1376. Transceiver controller 1372 also 
transfers information between IR receiver 1367b and processor 1354 (Fig. 17A). The 
processor may also control devices that are connected to the main RF signal path 1374 
and RF distribution system 1361 through a 360 MHz FSK transmitter 1366a, in 
similar fashion to that described above, but at a frequency of 360 MHz. 

RF modulator 1368 receives audio and video input from MPEG-2 chipset 
1356 (Fig. 17A). RF amplifier 1369 and non-reflective notch filter 1371 assure that 
only the desired signals are passed between RF modulator 1368 and main RF signal 
path 1374. 

This system allows simultaneous transmission of RF television signals and bi- 
directional control signals. Multiple IR remote transceivers 1362 can be installed in a 
single system. This system does not rely on the carrier firequency of the remote 
control, nor on a specific code implementation. The decoding of the codes and 
control of the IR emitters are under software control in the processor 1354. 
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Fig. 1 8 is a schematic view illustrating the location, and a possible 
implementation, of CO framer 1 100 and CP framer 1400 within the digital video and 
data deliveiy system of the present invention. CO framer 1 1 00 is located at central 
office 400 and resides on UAA module 1000 (not shown) and receives video 

5 programming content. CO framer 11 00 also receives and sends data services via the 

Internet 14. CO framer 1 100 communicates with modem 135 1 in order to 
communicate with corresponding modem 1351 located at customer premise 1300 via 
communication channel 16. CP framer 1400 is located within INI 1350 and outputs 
both a digital video program in MPEG-2 format to MPEG-2 decoder 1 356 and 

10 communicates data services with computer 1355 through network interface 1352. 

Fig. 19 is a schematic view illustrating CO framer 1 100 of Fig. 18. CO framer 
1 100 receives into packet identification (PID) filter 1110a program group, in the form 
of an adaptive style MPEG-2 transport stream, containing multiple programs over 
connection 1161. An MPEG-2 transport stream consists of a continuous stream of 

15 transport packets. All transport packets are 188 bytes in length. The first byte is set 
to the value 0 x 47 to aid in synchronization; this bit pattern is not unique and can 
occur elsewhere in the packet. Also included in the transport packet header is a 
packet identification (PID) field, this identifier distinguishes the pay load of the 
transport packet from the payloads of transport packets with other PID values. In 

20 accordance with the MPEG-2 protocol, a transport packet may contain a payload, an 
adaptation field, or an adaptation field followed by a payload. The adaptation field, 
when present, provides additional information about the data stream. 

One of these extra pieces of information is a program clock reference (PCR) 
value. Both the encoder and decoder of an MPEG-2 transport stream use 27 MHz 

25 clocks for their transactions. These clocks drive a system time counter (STC), which 
provides a constantly incrementing time stamp value. The encoder uses its own STC 
to time stamp the data being sent to the decoder. The decoder receives the data stream 
from the encoder, and uses its own STC to determine when to dispatch the time 
stamped data to its internal units. For simplicity, the encoder and decoder are not 

30 shown. However, since two completely different clocks are driving the STC counters. 
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there will inevitably be subtle variations between the two due to process variations, 
environmental conditions, etc. These variations could cause decoding errors when the 
data is received. As a result, a way of synchronizing the decoder's clock to the 
encoder's clock is desired, despite the fact that the two might be on opposite sides of 

5 the world. The solution described herein is to use the PGR value contained within the 

adaptation field. ^ 

The PGR value is a copy of the STG in the encoder exactly at the point in time 
when the PGR value is inserted into the transport stream as it leaves the encoder. 
ISO/IEG IS 13818-1, international standard (1994), MPEG-2 systems mandates that 

10 the transmission delay from the encoder to the decoder be a constant quantity. By 
requiring this, the transport packets arriving at the decoder will be at the exact same 
cadence and relative positioning in time as when they left the encoder. As a result, the 
decoder can compare the PGR value as it is received with the decoder's own local 
STG. If the received PGR (STG) is ahead of the local STG, then the decoder can infer 

15 that the local 27 MHz clock is slightly slower than the remote one. If the received 

PGR (STG) is behind the local STG, then the decoder can infer that the local 27 MHz 
clock is slightly faster than the remote one. The decoder's clock is designed to allow 
its rate to be subtly varied, and thus, it can utilize the information provided by the 
PGR value to align its STG to the STG at the remote encoder. 

20 Referring back to Fig. 1 9, packet identification (PID) filter 1 1 1 0 (to be 

described in detail with reference to Figs, 24A and 24B) receives the multiple 
program transport stream on connection 1 161 and distills the multiple program 
transport stream into a single program transport stream for output on connection 1 162. 
The resulting transport stream is sent to asynchronoxxs first-in first-out storage device 

25 (async FIFO) for temporary storage. 

PGR extract device 1 130 (to be described in detail with reference to Fig. 25) 
monitors the content of the single program group on connection 1 162 and searches for 
the presence of a PGR field. When PGR extract device 1 130 detects a PGR field, it 
extracts, or more accurately copies, the PGR field fi-om the stream and latches the 

30 PGR value into PGR incrementor 1 140 over connection 1 164. PGR incrementor 1 140 
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(to be described in detail with reference to Fig. 26) accepts the PGR field over 
connection 1 164 and increments its value by one on each 27 MHz cycle. PID filter 
1110, async FIFO buffer 1 125, PGR extract device 1 130 and PGR incrementor 1 140 
all operate from the common 27Mz clock provided by the backplane design, which 
delivers an adaptive style transport stream (Fig. 20A). Importandy, the 
aforementioned components within GO framer 1 100 are clocked by the same clock 
that is used for the adaptive style transport stream 1161 of Fig. 20A) that is input to 
GO framer 1 100, thus allowing the GO framer to be economically implemented as a 
synchronous unit. 

When GO data mux 1 1 50 (the operation of which will be described in detail 
with reference to Figs. 27 A, 27B, 27G and 27D) is ready to send an MPEG-2 packet, 
it examines the contents of async FIFO device 1 125 over connection 1 166. If there is 
a packet to be sent GO data mux sends the packet. If this packet contains a PGR field, 
GO data mux 1 150 knows that an adjusted version of the PGR field is available from 
PGR incrementor 1 140. In such a case, GO data mux 1 150 causes the PGR 
incrementor 1 140 to stop running by deasserting the PGR run signal on connection 
1 171, so that the output of PGR incrementor 1 140 stabilizes. GO data mux 1 150 
overwrites, or restamps, the adjusted PGR value for the original as the packet is being 
sent to modem 1351 (Fig. 18). If there is no MPEG-2 packet to be sent, GO data mux 
1 150 instead sends a packet containing data services from connection 1 169. As the 
video clock reference for MPEG-2 is encoded using a 27MHz clock, it should be 
noted that the preferred embodiment has utility when the data being clocked into the 
GO framer is clocked at that same rate, /.e., 27MHz. However, the PGR restamping 
feature of the GO framer of the present invention can successftilly operate whenever 
the GO framer is clocking in data at the same rate as the encoded video clock 
reference. Specifically, the GO framer of the present invention simply adjusts the 
PGR field by one unit on each 27Mz clock cycle of the adaptive style bus (Fig. 20A) 
until the packet is ready to be sent to the modem. 

GO data mux 1 150 also adds control channel 1 174 to the digital video content 
and the Internet data. Gontrol channel 1 174 is established by capitalizing on the 
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unused transport _priority flag bil present in each packet (whether digital video 
content, Internet data, or null) transported between central office 400 and customer 
premises 1300. Control information is transmitted over control channel 1 174, which 
is a low speed control data channel in both upstream and downstream directions, by 
using (or more accurately, overloading) the transport ^priority flag bit present in 
every transport packet that is communicated between central office 400 and customer 
premises 1300. CO framer 1 100 and CP framerl400 use this extra bit to form a serial 
stream in both the upstream and downstream directions, over which is communicated 
control information such as programming requests from a user located at customer 
premises 1300. In this manner, it is possible to transmit low speed serial messages 
without interfering with the MPEG-2 program or regular data services. A universal 
asynchronous receiver transmitter (UART) unit within CO framer 1 100 and CP 
framer 1400 generates and receives serial messages utilizing these bits, thus providmg 
a communication link between the host processors on either side of conununication 
channel 16. 

Fig. 20A is a schematic view illustrating the adaptive rate transport stream bus 
specification of the transport stream of Fig. 19. The adaptive style transport stream 
bus is clocked at a constant 27 MHz data rate, indicated by t=l/(27xl0* )sec, no 
matter the rate of the mcoming signal. Through the use of an extra D VALID bit, 
illustrated by signal 1 176 and also clocked at 27MHz, and which signifies whether its 
respective byte contains valid data, the bus allows a transport stream of an arbitrary 
data rate (up to 8 x (27x10^) b/s) to be transmitted. An extra packet sync bit 
(PSYNC), represented by signal 1 177 is added to mark the first byte in every MPEG- 
2 transport stream packet. This design allows the present invention to be very 
versatile in accepting input transport streams of many different telephony rates. 
Useful data is extracted from transport stream 1 161 by storing only those bytes whose 
associated DVALID signal on line 1 1 76 are asserted active. Of this useful data being 
extracted, the receiving device knows that the PSYNC signal on line 1 177 is asserted 
on the first byte of every treinsport packet. 
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Fig. 20B is a schematic view illustrating the formatting used to transport eight 
sets of the adaptive rate transport stream of Fig. 20A over an optical link. The 
adaptive rate transport stream of Fig. 20A is comprised of eight 10-bit parallel data 
streams. The eight streams are combined to form a basic 80-bit word. The serial 
stream is organized into frames, an exemplary one of which is illustrated as frame 
1201. Each frame includes an 80-bit overhead word 1201a, an 80-bit rate-adjustment 
word 1201b and thirteen 80-bit pay load words 1201c through 120 In, resulting in a 
frame of 1200 bits in length. 

Overhead word 1201a includes 32 framing bits 1202 and a four bit payload 
pointer 1206 with forty-four 1204 unused bits in between. The framing bits indicate 
the start of a frame and are used to synchronize the serial data to the output parallel 
data in remote video input module 825 (discussed with respect to Fig. 1 IC). The 
payload pointer 1206 indicates whether the payload data begins in the rate adjustment 
word 1201b, first payload word 1201c, or second payload word 120 Id (not shown). 
In this manner, the serial data stream adjusts the data rate to match the input data rate. 
Note that the 80-bit overhead word 1201a is divided into ten 8-bit bytes, but the rate 
adjustment word 1201b and the payload words 1201c-1201n are divided into eight 10- 
bit parallel adaptive rate transport streams, each including eight data bits, DVALID bit 
1 176 (Fig. 20A), and PSYNC bit 1 177 (Figs. 20A and 21). 

Fig. 21 is a schematic view illustrating an arbitrary rate program stream from 
which the adaptive style transport stream at the rate of 27 MHz (Fig. 20A) is created. 
The arbitrary rate transport stream illustrated by signal 1161 is converted through the 
use of the selective clocking enabled by the DVALID and PSYNC bits of Fig. 20A. 
As can be seen interval t=l/a sec, where 0<a<27xl0^ In this manner, any arbitrary 
transport stream may be adaptively converted to the 27MHz transport stream 
illustrated in Fig. 20A. 

Fig. 22 is a transport stream definition table taken from ISO/IEC 1 13818-1- 
Table 2-3, which defines a transport packet per ITU-T Rec. H.222.0, which defines 
the first three bytes of the transport stream packet of Figs. 20 A, 20B and 21 . 
Illustratively, the first three bytes of each packet are sufficient to determine the PID 
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field of each packet. Note that byte two contains bits 4-0 PID [12:8] packet ID high 
(PIDH), while byte three contains bits 7-0, PID [7:0] identifying, packet ID low 
(PIDL). The use of the PIDH and PIDL bits will be discussed in detail with reference 
to Figs. 24A-B. 

5 Fig. 23 is a schematic view illustrating the digital video program group 

contained on connection 1161 of Fig. 19. A program group consists of one or more 
programs, illustrated by channels 1 178 containing, for example, cable news network 
(CNN) and channel 1 179 containing, for example, home box office (HBO). While 
two channels are shown for simplicity, many channels can simultaneously be carried 

1 0 in each program group. These programs are distinguished through the use of the 
packet ID (PID) field. Shown is a sample program group in which the several 
programs contained in the program group are filtered down to a single program, 
illustratively ordered by an end user, illustrated as CNN program 1 178 emanating 
from packet ID filter operation 1110. 

15 Fig. 24A is a schematic view illustrating PID filter 1110 of Fig. 19. PID filter 

1 1 10 is comprised of a plurality of 8-bit latches 1 1 1 la-1 1 1 In, each configured to 
receive the 8-bit transport stream on connection 1161. Latches 1111 also include two 
additional bits, the PSYNC bit which is received on connection 1 177 and the 
DVALID bit which is received over connection 1 1 76. The DVALID bit on 

20 connection 1 1 76 supplies the clock enable signal to 8-bit latches 1111. In conjunction 
with that described in Figs. 20A, 20B and 22, PID filter 1110 sets the DVALID flag 
low for all packets that contain undesired PID values. In this manner, only the desired 
program is extracted from transport stream 1161, containing the program group, 
through analysis of the PIDL bits on connection 1 1 16 and the PIDH bits on 

25 connection 1117. The PIDL bits on connection 11 1 6 and the PIDH bits on connection 
1117 form the current packet identification byte on connection 1118. 

Comparator 1121 analyzes the current PID value on connection 1 1 18 and the 
desired PID value on connection 1 1 19 and if they match, le,, the current PID 1 1 18 is 
the desired PID 1119, then comparator 1121 supplies an input to latch 1 122. If the 

30 PSYNC signal is asserted on connection 1 177 and the comparator asserts a signal on 
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connection 1191 then latch 1 122 asserts a signal on connection 1 192 for input to and 
gate 1112. If and gate 1112 receives input from latch 1 122 and the DVALID signal 
asserted on 1 176, then and gate causes the DVALID signal to be deasserted through 
latch 1114, while the filtered program group containing the desired packet ID is 

5 supplied on connection 1 162 to async FIFO buffer 1 125 (Fig. 19) and PGR extract 
device 1130 (Fig. 19). 

Fig. 24B is a decision flow diagram illustrating the operation of the PID filter 
1110 of Fig. 24 A. In block 1 123 the PID filter receives a new packet. In block 1 124 
it is determined whether this packet contains the desired PID value. If the PID value 

10 is as desired, then in block 1 126 packet ID filter will await the next packet. If the PID 
value is not as desired, then in block 1 127 PID filter 1110 v^ll mark the packet as 
invalid and then await the next packet in block 1 1 26. 

Fig. 25 is a decision flow diagram illustrating the operation of the PGR extract 
device 1 1 30 of Fig. 1 9. In block 1131, PGR extract device receives a new packet. In 

15 1132, PGR extract device 1 130 determines whether the packet contains a PGR value. 
If no PGR value is contained in the new packet, then PGR extract device 1 130 will 
await the next packet in block 1 1 34. Should the packet contain a PGR value, then 
PGR extract device 1 130 will latch that value into the PGR incrementor 1 140 in block 
1136. PGR extract device 1 1 30 then awaits the next packet in block 1 1 34. 

20 Fig. 26 is a detailed view of the PGR incrementor 1 140 of Fig. 19. On line 

1 1 64, mux 1141 receives a new PGR value from PGR extract device 1130. When 
instructed by the assertion of PGR run signal on connection 1171, PGR register 1 144 
will store the new PGR value received through mux 1 141 on connection 1 147. PGR 
register 1 144 is typically a 43-bit register. Either the new PGR value supplied on 

25 connection 1 1 64 or the current PGR value plus one supplied on connection 1 1 46 is 
latched into PGR register 1 144 on every 27 MHz clock cycle so long as the PGR run 
signal is asserted on connection 1171. The current value of the register is provided to 
CO data mux 1150 over connection 1 1 67 so that GO data mux 1 1 50 can reinsert this 
field back into the MPEG-2 stream as it is being sent over connection 1 168 to 

30 customer premise 1300 (see Fig. 19). This technique allows the PGR field to be 
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adjusted by the correct amount in order to maintain its accuracy. For every 27 MHz 
clock cycle, the PGR laden transport packet is delayed, the PGR field is incremented 
one unit to compensate. When GO data mux 11 50 is ready to send the PGR laden 
transport packet to customer premise 1300, it stops the PGR incrementor from running 

5 by deasserting the PGR run signal on connection 1 1 71, and loads the updated PGR 

field back into its original transport packet (this will be illustrated in detail with 
reference to Fig. 28). 

Referring back to Fig. 19, by using a transport stream interface that clocks data 
along at 27 MHz, this same clock source can be used for the PID filter 1110, PGR 

10 extract device 1 130, async FIFO buffer 1 125, and PGR incrementor 1 140, whose PGR 
value is expressed in units of 27 MHz clock cycles. This allows all these units to be 
implemented as a simple synchronous hardware design. It should be noted that the 27 
MHz data clock associated with the incoming transport stream may well vary from the 
27 MHz clock used at the encoder. It is therefore likely that the amount added to the 

15 PGR field may vary very slightly with a value generated had the encoder clock been 
regenerated locally. However, the variation between the two clocks over the short 
time that the PGR incrementor 1 140 runs is extremely small. By using the data clock 
in lieu of attempting to regenerate the encoder clock, GO framer 1 1 00 significantly 
reduces the cost of implementation. Async FIFO buffer 1 125 and PGR run signal 

20 1171 provides a buffer between all other units and GO data mux 1 1 50, which is 

another purely synchronous design, thus regulated by the data clock provided by 
modem 1351. 

Fig. 27A is a block diagram illustrating CO data mux 1 1 50 of Fig. 1 9. Mux 
1151 receives a new value from PGR incrementor 1 140 over connection 1 167, 

25 receives data services input over connection 1 1 69, receives data from async FIFO 

buffer 1 125 in the form of a delayed program over connection 1 166 and receives input 
from decision maker 1 152. Decision maker 1 152 asserts or deasserts the PGR run 
signal on connection 1 171 in order to stop or continue operation of PGR incrementor 
1 140. Mux 1151 chooses to send data from async FIFO buffer 1 125, data services 

30 1 1 69, or replace a packet's PGR field with a new value over connection 1 1 67 based 
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upon current requirements. Mux 1151 provides the final transport stream over 
connection 1 168 to modem 1351 for transport over low bandwidth communication 
channel 16. 

Fig. 27B is a state diagram illustrating the operation of the decision maker 
1 1 52 of Fig. 27A. In states mO, ml and m2, a byte containing video programming 
content is read from async FIFO buffer 1 125 and sent over connection 1 168 to modem 
1351. In state m3, a byte is again read from async FIFO buffer 1 1 25 and sent to 
modem 1351. If bit 5 is set, go to state m4, else go to state mwait. In state m4, a byte 
is again read from async FIFO buffer 1 125 and sent to modem 1351. If zero, go to 
state mwait, else go to state m5. In state m5, a byte is again read from async FIFO 
buffer 1 125 and sent to modem 1351. If bit 4 is set, go to state m6, else go to state 
mwait If the state machine reaches the m6 state, then a PGR value is present in the 
packet, and therefore the old value is substituted with a new value as follows. 

In states m6, m7, m8, m9, mlO and mil, a byte is read from async FIFO 
buffer 1 125 and discarded. The PGR run signal on line 1 171 is deasserted. During 
each of the next six clock cycles, the six bytes associated with the new PGR field 
(connection 1 167) are transmitted in lieu of the six bytes associated with the old PGR 
field. 

In the mwait state, a byte is read from async FIFO buffer 1 125 and sent to 
modem 1 35 1 and the next packet decision (1 1 52) is awaited. 

In state iO a standard MPEG-2 synch byte (0x47) is sent to modem 1351. In 
state il, the byte Ox IF is sent to modem 1351. In state i2, the byte OxFE is sent to 
modem 1351. In state i3, the byte Ox la is sent to modem 1351, where a is the 
appropriate continuity_counter value. States il and i2 transmit the PID value to be 
used for the Intemet data; in this preferred embodiment the PID value of OxlFFE is 
used. It should be noted that any arbitrary value may be used provided it is consistent 
across the design and does not conflict with any other PID's being used. The 
continuity counter is a standard 4-bit field that is incremented once for every transport 
packet of the same PID as is known in the art. In the iwait state, a byte of Intemet 
data is sent to modem 1351 and the next packet decision (1 1 52) is awaited. 
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In state nO. a standard MPEG-2 synch byte (0x47) is sent to modem 1351. In 
state nl , the byte Ox IF is sent to modem 1351 . In state n2, the byte OxFF is sent to 
modem 1351. In state n3, the byte Ox 1 p is sent to modem 1351, where p is the 
appropriate continuity_counter value. In state nwait, the byte OxFF is sent to modem 
5 1351 and the next packet decision (1152) is awaited. 

Fig. 27C is a flow chart illustrating the operation of CO data mux 1 150 of Fig. 
27 A. In block 1 153, CO data mux 1 150 is ready to send a new packet, in block 11 54, 
it is determined whether there is an MPEG-2 program packet ready to be sent from 
connection 1 166 (Fig. 19). If an MPEG-2 program packet is available, then it is sent 

10 over connection 1 1 68 to modem 1351 in block 1 1 56. If there is not an MPEG-2 

program packet ready, then in block 1 155 CO data mux 1150 will determine whether 
the data quota has been reached. If the data quota has been reached, then in block 
1 157, CO data mux 1 150 will send a null packet. If it is determined in block 1 155 
that the data quota has not been reached, then CO data mux 1 150 will send a data 

15 services packet in block 1 1 58. 

Fig. 27C is a flow chart illustrating the CO data mux program packet decision 
making function 1 152 of Fig. 27A. In block 1 1 81, the choice has been made to send 
an MPEG-2 program packet, block 1181 corresponding with block 1 156 of Fig. 27B. 
In block 1 1 82, it is determined whether the packet to be sent contains a PCR value. If 

20 the packet does not contain a PCR value, then in block 1 1 83, the MPEG-2 program 
packet is sent. If in block 1 1 82, it is determined diat the packet does contain a PCR 
value, then in block 1 184, the PCR run signal on connection 1 171 (Fig. 19) is 
deasserted and the old PCR value is replaced with the new PCR value available on 
connection 1 1 67. 

25 Fig. 28 is a schematic view illustrating the downstream (from central office 

400 to customer premises 1300) operation of CO framer 1 100 of Fig. 19. Individual 
packets from multiple program source transport stream 1 161 are selectively forwarded 
to the slower transport stream 1 168 destined for modem 1351 by latching the 
extracted PCR value on connection 1 164 (Fig. 19) into PCR incrementor 1 140 over 

30 connection 1 1 72 and deassertmg the PCR run signal 1 1 7 1 to PCR incrementor 1 140 
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(Fig. 19). PGR field adjustment is performed on packets that contain the PGR field in 
accordance with the description of Fig. 26. 

Fig. 29 is a schematic view illustrating the CO data mux of GO framer 1 100 of 
Fig. 19 in an upstream (customer premises 1300 to central office 400) direction. 
5 Although omitted for simplicity from Fig. 19, GO framer 1 100 includes in addition to 
CO data mux 1 1 50, GO data demux 1 155. CO data demux 1155 receives bi- 
directional Internet data from customer premises 1300 over cormection 1 168 and 
control information over control channel 1 174. CO data demux routes the Internet 
data to, for example, computer 1355 (not shown) over connection 1 169. The 

10 operation of control channel 1 174 is as discussed above. 

Fig. 30 is a schematic view illustrating the CP data demux 1455 in a 
downstream direction. The video programming content and data is received on 
connection 1456 from DSL modem 1351. CP data demux 1455 separates the video 
programming content for input to MPEG-2 decoder 1356 (Fig. 18) over connection 

15 1457 and the bi-directional Internet data for input to computer 1355 (Fig. 1 8) over 

connection 1459. Also providing input to CP data demux 1455 is control channel 
11 74 the operation of which was discussed with respect to Fig. 19. 

Fig. 3 1 is a schematic view illustrating CP data mux 1450 of the CP framer 
1400 of Fig. 17A in an upstream direction. Bi-directional Internet data is received in 

20 CP mux 1450 over connection 1459 and transported to DSL modem 1351 for 

communication over communication channel 16. Note that CP data mux 1450 sends 
only bi-directional Internet data and control information over control channel 1 174 in 
the upstream direction. 

Fig. 32 is a decision flow diagram illustrating the operation of both CO data 

25 demux 1 1 55 and CP data demux 1 455. Block 1 1 86, signifies the arrival of a new 

packet. In block 1 187 it is determined whether the packet contains data services. If 
the packet does not contain data services, then in block 1 188, the data demux awaits 
the next packet. If it is determined in block 1 1 87 that the packet does contain data 
services, then in block 1 1 89, the data services are extracted and the data demux awaits 

30 the next packet in block 1 188. 
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Fig. 33 is a flow chart illustrating the operation of CP data mux 1450 of Fig. 
17 A. In block 1401, CP data mux 1450 is ready to send a new packet. In block 1 402, 
it is determined whether the data quota has been reached. If the data quota has been 
reached, then in block 1404 CP data mux 1450 will send a null packet. If in block 
1402, it is determined that the data quota has not been reached, then in block 1406, CP 
data mux 1450 will send a data services packet through modem 1351 over 
communication channel 16 to central office 400. This illustrates that upstream data is 
formatted in transport packets as well. Although not necessary for the design of the 
present invention to function, it promotes standardization. CP data mux 1450 
generates only data service and null packets. 

Fig. 34 is a schematic view illustrating an alternative embodiment of CO 
framer 1 100 of Fig. 19. In this embodiment, CO framer 1 100 adds a new program to 
an existing transport stream. Items performing like functions to those described with 
reference to Fig. 19 are given the same reference numerals and will not be described 
15 in detail again. As can be seen, a program to be added is supplied on connection 1551 
to async FIFO buffer 1 125. PCR extractor 1 130 also monitors the transport stream on 
connection 1551 in similar fashion to monitoring the output of PID filter 1 1 10 of Fig. 
19. PCR extractor 1 130, PCR incrementor 1 140 and async FIFO buffer 1 125 all 
perform the same function as described above. Program mux 1550 replaces CO data 
20 mux 1 1 50, and receives existing program streams over connection 1 552. Program 

mux 1550 will substitute incoming null packets with packets associated with the new 
program and supply an output on connection 1 554 comprising the new n + 1 program 
stream. 

Many variations and modifications may be made to the above-described 
25 embodiment(s) of the invention without departing substantially from the scope and 
principles of the invention. All such modifications and variations are intended to be 
included herein within the scope of the present invention. 



48 



wo 99/23774 



PCT/US98/23497 



CLAIMS 

Therefore, having thus described the invention, at least the following is claimed: 

1 . A software management system for managing a digital video and data 
delivery system in which a plurality of channels are simultaneously available to at 
least one user, and wherein said user may request at least one of said plurality of video 
channels, comprising: 

means for managing a database containing user information; 

means for managing a plurality of channels including a plurality of video 
channels available on a bus and at least one bi-directional data channel; 

means for communicating with a plurality of central office master 
workstations in order to exchange information relating to said user information and 
said plurality of channels; 

means for processing a request from said user to view one of said plurality of 

video channels; and 

means for delivering said at least one of said plurality of video channels and 
said at least one bi-directional data channel to said user over a communications 
channel, 

2. The system as defined in claim 1 , further comprising means for 
interfacing said user information to a billing system. 

3 . The system as defined in claun 1 , further comprising means for 
simultaneously providing with said at least one video channel and said at least one bi- 
directional data channel, at least one telephone channel . 
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4. A software management system for managing digital video and data 
delivery equipment in which a plurality of channels are simultaneously available to at 
least one user, and wherein said user may request any one of said plurality of 
channels, comprising: 

means for managing a database containing subscriber information; 

means for monitoring a plurality of channels, including a plurality of video 
channels available on a bus and at least one bi-directional data channel; 

means for processing a request from a user to view at least one of said 
plurality of video channels; 

means for assigning a communications port to said user when said user 
requests to be a subscriber; and 

means for delivering said at least one of said plurality of video channels and 
said at least one bi-directional data channel to said user over a communications 
channel. 

5. The system as defined in claim 4, further comprising: 

means for monitoring each of said plurality of channels requested by said user 
in order to develop a viewing history for each said user; 

means for recording said history to said database; and 

means for communicating said history to a system management workstation. 

6. The system as defined in claim 4, further comprising means for 
simultaneously providing with said at least one video channel and said at least one bi- 
directional data channel, at least one telephone chamieL 

7. The system as defined in claim 6, wherein said telephone channel is a 
digital telephone channel. 
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User Interface 



6Sl 



• Provide interface to subscriber database for UAA 
assignments. 

• Provide interface to configure & monitor CO equipment 

• GraphtcaUUser Interface via Java and HTM). • 



/Subscriber Database & Contror\ 

• Maintain localized mirror of SMW 
database for subscriber info: 

• video channel authorizations 

• Internet service authorization 

• account activity (PPV info) 

• service enabled / disabled 

• channel viewing statistics 

• Upload billing info & download 
subscriber info 

• Configure UAA for service ^^2^ 

• initial setup 

• change in service . 




Hardware Setup & Status Diapiay 

• Inttiaftzation of CO equipment 

• Monitor status of CO equipment 

• Manage polling of Shelf Processors for status info 

• Manage polling of UAAs for PPV buys 

• Access database of card configurations 
for rapid reconfiguration in case large 
number of cards replaced simultaneously 




Embedded Control Network 

• Responsible for the communication of information 
t>etween the COM and the CO equipment 

• API will define types of messages/ commands that 
system supports 

• some portions of this code will be common with 
the embedded controllers 




To Global Bus 



To SMW 
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